fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
↳ QTRS
↳ Non-Overlap Check
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
fib1(x0)
fib12(x0, x1)
add2(0, x0)
add2(s1(x0), x1)
sel2(0, cons2(x0, x1))
sel2(s1(x0), cons2(x1, x2))
FIB12(X, Y) -> ADD2(X, Y)
ADD2(s1(X), Y) -> ADD2(X, Y)
SEL2(s1(N), cons2(X, XS)) -> SEL2(N, XS)
FIB1(N) -> SEL2(N, fib12(s1(0), s1(0)))
FIB12(X, Y) -> FIB12(Y, add2(X, Y))
FIB1(N) -> FIB12(s1(0), s1(0))
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
fib1(x0)
fib12(x0, x1)
add2(0, x0)
add2(s1(x0), x1)
sel2(0, cons2(x0, x1))
sel2(s1(x0), cons2(x1, x2))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
FIB12(X, Y) -> ADD2(X, Y)
ADD2(s1(X), Y) -> ADD2(X, Y)
SEL2(s1(N), cons2(X, XS)) -> SEL2(N, XS)
FIB1(N) -> SEL2(N, fib12(s1(0), s1(0)))
FIB12(X, Y) -> FIB12(Y, add2(X, Y))
FIB1(N) -> FIB12(s1(0), s1(0))
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
fib1(x0)
fib12(x0, x1)
add2(0, x0)
add2(s1(x0), x1)
sel2(0, cons2(x0, x1))
sel2(s1(x0), cons2(x1, x2))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
SEL2(s1(N), cons2(X, XS)) -> SEL2(N, XS)
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
fib1(x0)
fib12(x0, x1)
add2(0, x0)
add2(s1(x0), x1)
sel2(0, cons2(x0, x1))
sel2(s1(x0), cons2(x1, x2))
The following pairs can be strictly oriented and are deleted.
The remaining pairs can at least by weakly be oriented.
SEL2(s1(N), cons2(X, XS)) -> SEL2(N, XS)
trivial
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
fib1(x0)
fib12(x0, x1)
add2(0, x0)
add2(s1(x0), x1)
sel2(0, cons2(x0, x1))
sel2(s1(x0), cons2(x1, x2))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
ADD2(s1(X), Y) -> ADD2(X, Y)
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
fib1(x0)
fib12(x0, x1)
add2(0, x0)
add2(s1(x0), x1)
sel2(0, cons2(x0, x1))
sel2(s1(x0), cons2(x1, x2))
The following pairs can be strictly oriented and are deleted.
The remaining pairs can at least by weakly be oriented.
ADD2(s1(X), Y) -> ADD2(X, Y)
[ADD1, s1]
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
fib1(x0)
fib12(x0, x1)
add2(0, x0)
add2(s1(x0), x1)
sel2(0, cons2(x0, x1))
sel2(s1(x0), cons2(x1, x2))
↳ QTRS
↳ Non-Overlap Check
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
FIB12(X, Y) -> FIB12(Y, add2(X, Y))
fib1(N) -> sel2(N, fib12(s1(0), s1(0)))
fib12(X, Y) -> cons2(X, fib12(Y, add2(X, Y)))
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
sel2(0, cons2(X, XS)) -> X
sel2(s1(N), cons2(X, XS)) -> sel2(N, XS)
fib1(x0)
fib12(x0, x1)
add2(0, x0)
add2(s1(x0), x1)
sel2(0, cons2(x0, x1))
sel2(s1(x0), cons2(x1, x2))